IN THE CLAIMS: 

This listing of claims will replace all prior versions, and listings, of claims in the 
present application: 

1 . (Currently amended) A method of operating a data storage system configured to 
perform data mirroring, the method comprising: 

receiving a set of data, the set of data having a first number of subsets; 

defining a compression group corresponding to the set of data, the compression 
group having a plurality of entries, each entry containing a pointer to a corresponding 
one of the subsets; 

compressing the set of data so that the set of data occupies a smaller number of 
the subsets than the first number; 

for each of the subsets which does not contain compressed data after said 
compressing, storing a predetermined value in the corresponding entry of the 
compression group, the predetermined value being indicative that corresponding data is 
compressed; and 

at a cons i stency po i n t during a logical mirroring operation , sending the set of data 
in its entirety from said data storage system t o a remote data storage system at a mirror 
site, for use in a mirror copy of the set of data, if the set of data has been compressed 
and any one or more of the subsets of the set of data has been modified since a prior 
cons i stency po i nt looical mirroring operation, to enable the remote data storage system 
to update the mirror copy of the set of data . 
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2. (Original) A method as recited in claim 1 , wherein the predetermined value further is 
indicative that the corresponding compressed data is represented in a different entry of 
the compression group. 

3. (Original) A method as recited in claim 1 , wherein the predetermined value further is 
indicative of the compression algorithm used to compress the data. 

4. (Original) A method as recited in claim 1 , wherein the set of data is a portion of a 
file, and each of the subsets of the set of data is a separate block within said portion of 
the file. 

5. (Original) A method as recited in claim 4, wherein said method is performed in 
response to a request to write the file; and 

wherein the method further comprises writing the portion of the file to a non- 
volatile storage device after said compressing. «■ 

6. (Original) A method as recited in claim 5, wherein said writing the portion of the file 
to the non-volatile storage device is performed after said compressing but before any 
other portion of the file is received by the data storage system. 

7. (Original) A method as recited in claim 4, wherein the compression group is a 
portion of an indirect node of the file. 

8. (Original) A method as recited in claim 4, wherein the compression group is a 
portion of an inode node of the file. 
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9. (Currently amended) A method as recited in claim 1 , further comprising: 

saving an uncompressed version of the port i on of the set of data in a memory in 
the data storage system after said compressing; and 

in response to a subsequent request on-for the set of data, using the 
uncompressed version of the data from the memory to fulfill the request. 

10. (Original) A method as recited in claim 1 , further comprising; 

receiving a read request; 

in response to the read request, determining that the read request relates to at 
least one subset of the set of data; 

scanning the compression group to determine whether any entry in the 
compression group contains the predetermined value; and 

upon detecting the predetermined value in any of the entries in the compression 
group, immediately beginning decompression of the set of data. 

11-12. (Canceled) 

13. (Currently amended) A method of operating a data storage system configured to 
perform data mirroring, the method comprising: 
receiving a file containing data; 

compressing at least part of the file to form a plurality of compression groups, 
each of the compression groups representing less than the entire file, each of the 
compression groups corresponding to an independently compressible group of data; 
and 

at a cons i stency po i nt durina a logical mirroring operation . 

P01-1733 7 
A/N: 10/755,020 



determining whether any data represented by one of the compression 
groups has been modified since a prio r cons i stoncv po i n t logical mirroring operation , 
and 

if any data represented by said one of the compression groups has been 
modified since a prior conoiotoncv po i nt logical mirroring operation , sending said one of 
the compression groups in its entirety from the data storage system to a remote data 
storage system at a mirror site, for uso i n to enable the remote data storage system to 
update a mirror cop y of the file . 

14. (Original) A method as recited in claim 13, wherein each of the compression 
groups represents a plurality of blocks of the file. 

15. (Original) A method as recited in claim 13, wherein said compressing at least part 
of the file comprises compressing the data represented by each of the compression 
groups independently. 

16. (Original) A method as recited in claim 15, further comprising determining 
suitability for compression independently for each of the compression groups. 

17. (Original) A method as recited in claim 13, wherein each of the compression 
groups contains a plurality of pointers. 

18. (Original) A method as recited in claim 17, wherein at least one of the pointers in 
each of the compression groups points to compressed data, and wherein at least one 
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other pointer in each of the compression groups is a predetermined value indicative that 
corresponding data has been compressed. 

19. (Original) A method as recited in claim 18, wherein the predetermined value further 
is indicative of the compression algorithm used to compress the data. 

20. (Currently amended) A method of operating a data storage system configured to 
perform data mirroring, the method comprising: 

receiving a file at the data storage system, a portion of the file including a number 
of consecutive blocks of uncompressed data, 

defining a compression group to represent the portion of the file, including 
defining the compression group to have a plurality of entries and filling each of the 
entries with a block number that points to a corresponding one of the blocks; 

determining whether the portion of the file is suitable for compression; and 

if the portion of the file is determined to be suitable for compression, then 

compressing the portion of the file so that the portion occupies a smaller 
number of consecutive blocks, 

for each of the number of consecutive blocks which does not contain 
compressed data after said compressing, storing a predetermined block number in the 
corresponding entry of the compression group, the predetermined block number being 
indicative that corresponding data is compressed and represented elsewhere in the 
compression group; and 

at a mirroring event: 



P01-1733 

A/N: 10/755,020 



9 



scanning the compression group to determine whether the portion of the 
file has been compressed, and 

determining whether any block in the portion of the file has been modified 
since a prior mirroring event, and 

if the portion of the file has been compressed and at least one block in the 
portion of the file has been modified since the prior mirroring event, sending the portion 
of the file in its entirety to a remote data storage system at a mirror site, for uso into 
enable the remote data storage system to maintain a mirror copy of the file. 

21 . (Original) A method as recited in claim 20, further comprising repeating said 
defining a compression group so as to define a plurality of compression groups to 
represent the file. 

22. (Original) A method as recited in claim 21 , wherein each compression group 
represents a portion of an indirect node of the file. 

23. (Original) A method as recited in claim 21 , each compression group represents a 
portion of an inode node of the file. 

24. (Original) A method as recited in claim 20, wherein the predetermined block 
number further is indicative of the compression algorithm used to compress the data. 

25. (Original) A method as recited in claim 20, wherein the file comprises a plurality of 
portions, each including a plurality of blocks of data, and wherein the method further 
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comprises repeating said defining, determining, compressing, and storing, for each of 
the plurality of portions. 

26. (Original) A method as recited in claim 20, further comprising, in response to a 
read request, determining that the portion of the file is compressed by scanning the 
compression group for the predetermined block number. 

27. (Original) A method as recited in claim 20, wherein said method is performed in 
response to a request to write the file; and 

wherein the method further comprises writing the portion of the file to a non- 
volatile storage device after said compressing. 

28. (Original) A method as recited in claim 27, wherein said writing the portion of the 
file to the non-volatile storage device is performed after said compressing but before 
any other portion of the file is received by the data storage system. 

29. (Original) A method as recited in claim 27, further comprising: 

saving an uncompressed version of the portion of the file in a memory in the data 
storage system after said compressing; and 

in response to a subsequent request on the portion of the file, using the 
uncompressed version from the memory to fulfill the request, without decompressing 
the compressed portion of the file. 

30. (Original) A method as recited in claim 20, further comprising; 

receiving a read request at the data storage system; 
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in response to the read request, determining that the read request relates to at 
least one block of the portion of the file; 

scanning the compression group to determine whether any entry in the 
compression group contains the predetermined block number; and 

upon detecting the predetermined block number in any of the entries in the 
compression group, immediately beginning decompression of the portion of the file. 

31-32. (Canceled) 

33. (Original) A method as recited in claim 20, wherein consecutive entries in the 
compression group correspond to consecutive blocks in the file. 

34. (Currently amended) A method of compressing data in a data storage system, the 
method comprising: 

receiving a request to write a file at the data storage system; 

in response to the request, identifying a plurality of portions of the file, each 
portion including a number of consecutive blocks of uncompressed data; 

defining a separate compression group to represent each of the portions, so as 
to define a plurality of compression groups to represent the file, including defining each 
compression group to include a plurality of entries, wherein each of the entries is filled 
with a block number that points to a corresponding one of the blocks, wherein 
consecutive entries in the compression group correspond to consecutive blocks in the 
file; 

determining whether each of the portions of the file is suitable for compression; 
for each portion, if the portion is determined to be suitable for compression, 
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compressing the portion into a smaller number of consecutive blocks, and 
for each block which does not contain compressed data after said 
compressing, storing a predetermined block number in the corresponding entry of the 
compression group, the predetermined block number being indicative that 
corresponding data is compressed and represented elsewhere in the compression 
group; 

writing the file to a non-volatile storage device after said compressing; and 
at a mirroring event, 

scanning one of the compression groups to determine whether the 
corresponding portion of the file has been compressed, and 

determining whether any block in the corresponding portion of the file has 
been modified since a prior mirroring event, and 

if the corresponding portion of the file has been compressed and at least 
one block in the corresponding portion of the file has been modified since the prior 
mirroring event, sending the corresponding portion of the file in its entirety to a remote 
data storage system at a mirror site, for us e i n t o enable the remote data storage system 
to maintain a mirror copy of the file. 

35. (Original) A method as recited in claim 34, wherein the predetermined block 
number further is indicative of the compression algorithm used to compress the data. 

36. (Original) A method as recited in claim 34, wherein each of the compression 
groups represents a portion of an indirect node of the file. 
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37. (Original) A method as recited in claim 34, wherein each of the compression 
groups represents a portion of an inode node of the file. 

38. (Original) A method as recited in claim 34, further comprising, in response to a 
read request, determining that a portion of the file is compressed by scanning the 
corresponding compression group for the predetermined block number. 

39. (Currently amended) A storage server comprising: 

a processor; 

a network communication interface to provide the data storage server with data 
communication with a plurality of clients over a network; 

a storage interface to provide the data storage server with data communication 
with a set of mass storage devices; and 

a memory containing code which, when executed by the processor, causes the 
data storage server to execute a first process of managing data in the mass storage 
devices on behalf of the clients, the first process comprising 

receiving a set of data, the set of data having a first number of subsets, 

creating a compression group corresponding to the set of data, the 
compression group having a plurality of entries, each entry containing a pointer to a 
corresponding one of the subsets, 

compressing the set of data so that the set of data occupies a smaller 
number of the subsets than the first number, and 

for each of the subsets which does not contain compressed data after said 
compressing, storing a predetermined value in the corresponding entry of the 
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compression group, the predetermined value being indicative that corresponding data is 
compressed; 

the memory further containing code which, when executed by the processor, 
causes the data storage server to execute a second process of causing data stored in 
the mass storage devices to be mirrored at a remote site, the second process 
comprising, at a mirroring event, sending the set of data in its entirety to a remote data 
storage system at a mirror site, for use m-bv the remote data storage system to update 
a mirror copy of the set of data, if at least one of the subsets of the set of data has been 
modified since a prior mirroring event. 

40. (Original) A storage server as recited in claim 39, wherein said process of 
managing data is performed by a file system layer of the data storage server. 

41 . (Original) A storage server as recited in claim 39, the predetermined value further 
being indicative that the corresponding compressed data is represented in a different 
entry of the compression group. 

42. (Original) A storage server as recited in claim 39, wherein the predetermined value 
further is indicative of the compression algorithm used to compress the data. 

43. (Original) A storage server as recited in claim 39, wherein the set of data is a 
portion of a file, and wherein each of the subsets of the set of data is a separate block 
within said portion of the file. 
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44. (Original) A storage server as recited in claim 43, wherein the process of storing 
data in the mass storage devices is performed in response to a request to write the file 
from one of the clients; and 

wherein the process further comprises writing the portion of the file to a non- 
volatile storage device after said compressing. 

45. (Original) A storage server as recited in claim 44, wherein said writing the portion 
of the file to the non-volatile storage device is performed after said compressing but 
before any other portion of the file is received by the data storage system. 

46. (Original) A storage server as recited in claim 43, wherein the compression group 
represents a portion of an indirect node of the file. 

47. (Original) A storage server as recited in claim 43, wherein the compression group 
represents a portion of an inode node of the file. 

48. (Currently amended) A storage server as recited in claim 39, wherein the memory 
further contains code which, when executed by the processor, causes the data storage 
server to execute a third process, said third process comprising: 

saving an uncompressed version of the portion of the set of data in a memory in 
the data storage system after said compressing; and 

in response to a subsequent read on the portion of the set of data, using the 
uncompressed version from the memory to fulfill the request, without decompressing 
the portion of the set of data. 
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49. (Currently amended) A storage server as recited in claim 39, wherein the memory 
further contains code which, when executed by the processor, causes the data storage 
server to execute a third process, said third process comprising: 
receiving a read request; 

in response to the read request, determining that the read request relates to at 
least one subset of the set of data; 

scanning the compression group to determine whether any entry in the 
compression group contains the predetermined value; and 

upon detecting the predetermined value in any of the entries in the compression 
group, immediately beginning decompression of the set of data. 

50-58. (Canceled) 
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